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IMAGE READING METHOD INCLUDING SHADING CORRECTION AND 
IMAGE READING DEVICE THERE FOR 

[0001] This application is based on application No. 

5 2000-209934 filed in Japan, the entire content of which is 
hereby incorporated by reference. 
BACKGROUND OF THE INVENTION 

[0002] The present invention relates to an image reading 
method including shading correction and device therefor, 

10 and more particularly to an image reading method including 
peak-hold-type shading correction and device therefor. 
[0003] Generally, image readers (IRs) for optically 

reading document images suffers luminous energy distortion 
i.e. shading in photoelectric-converted outputs from image 

15 sensors due to a luminescence property of a light source, 
an optical imaging characteristic, and ununiform 
sensitivity of image sensors such as CCD (Charge Coupled 
Device) linear sensors. Electronic correction of the 
shading is mainly achieved through an average value type 

20 method and a peak hold type method that are disclosed for 
example in Japanese Patent Laid-Open Publication No. HE I 
10-271328 . 

[0004] In the average-value-type shading correction, 

image data for a plurality of lines on a shading plate 
25 (white plate) is read in advance, then an average value of 
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the image data is calculated per set of corresponding 
pixels on each line as shading correction reference data, 
and upon reading of documents, document image data is 
corrected based on the correction reference data. The 
5 average-value-type shading correction is not easily 
effected by the influence of S/N (signal to noise) ratio of 
a system, but susceptible to "dirt" attached to the shading 
plates. In addition, the average-value-type shading 

correction requires a memory having a large capacity. 
10 [0005] In the peak-hold-type shading correction, on the 
other hand, image data for a plurality of lines on a 
shading plate is read in advance, then a peak value of the 
image data is held per set of corresponding pixels on each 
line as shading correction reference data, and upon reading 
15 of documents, document image data is corrected based on the 
correction reference data. The peak-hold-type shading 
correction is not susceptible to "dirt" present on the 
shading plate and it does not require a large capacity of 
memory. However, the peak-hold-type shading correction is 
20 easily effected by the influence of S/N ratio. 

[0006] Generally, since sufficient exposure was 

obtainable in the past, S/N ratio of a system was 
satisfactorily large and a difference "d" between a peak 
value "p" and an average value "a" upon reading was small 
25 as shown in Fig. 12A. Therefore, the peak hold method was 
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used without any problem. 

[0007] In recent years, however, it is difficult for 

digital copying machines and the like to obtain sufficient 
exposure from image readers because of demands for high CPM 
5 (copied pages per min.) and low power consumption. In 
addition, high resolution and high CPM increase clock 
frequencies, which generates larger noises in a GND 
(ground) line, resulting in insufficient voltage of analog 
image signals outputted by CCD sensors. Because of these 

10 reasons, S/N ratio of a system is getting small and a 
difference d' between a read peak value p' and an average 
value a' is increasing as shown in Fig. 12B. This 
increases a peak hold value (shading correction reference 
data) p' , with which an amplification coefficient of the 

15 shading correction is decreased. For example, in the case 
where a white color in the same level as the shading plate 
is corrected to a step value of 255, the amplification 
coefficient is decreased from A to A' . As a result, an 
intensity level of the entire image is degraded, which 

20 causes a so-called "low-key" tendency. In the case of 
color copying machines, there arises a problem of change in 
shades of colors. More particularly, a sensitivity of 
color copying machines is generally different by RGB (red 
green blue) , and therefore S/N ratio and a S/N ratio 

25 fluctuation amount are different per RGB. The color 
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copying machines are usually tuned in such a way that 
identical RGB readings are obtained when a gray patch is 
read in a standard S/N ratio condition. However, the S/N 
ratio is different per RGB, which causes a phenomenon that 
5 a certain wavelength element is displaced in low-key 
direction whereas another wavelength element is displaced 
in high-key direction. As a result, dispersion is 

generated in readings between RGB, which causes change in 
shades of colors, that is, a color tone regardless of a 

10 gray patch. 

[0008] In a system having inappropriate S/N ratio, the 

dispersion in the S/N ratio among individual machines is 
also large. Consequently, the S/N ratio causes larger 
dispersion in readings of an document image after 

15 application of shading correction, which makes the above- 
stated problems aggravated. 
SUMMARY OF THE INVENTION 

[0009] It is an object of the present invention to 

provide an image reading method and device performing a 

20 peak-hold-type shading correction, which is capable of 
decreasing dispersion in readings of document images after 
application of shading correction caused by S/N ratio. 
[0010] In order to accomplish the above object, a first 
aspect of the present invention provides an image reading 

25 method for obtaining a shading correction coefficient for 
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correcting image data obtained by reading a document image, 
comprising the steps of: reading a reference plate in a 
main scanning direction plural times at different positions 
in a sub-scanning direction perpendicular to the main 
5 scanning direction with use of a plurality of image sensors 
aligned in the main scanning direction; calculating 
difference per image sensor between a maximum value among a 
plurality of readings from each image sensor and an average 
value of readings from each image sensor; and obtaining the 
10 shading correction coefficient by modifying a correction 
coefficient for correcting the image data so that the 
maximum value of each image sensor becomes a specified 
image level in correspondence to the difference of each 
image sensor. 

15 [0011] A second aspect of the present invention provides 

an image reading method for obtaining a shading correction 
coefficient for correcting image data obtained by reading a 
document image, comprising the steps of: reading a 
reference plate in a main scanning direction plural times 

20 at different positions in a sub-scanning direction 
perpendicular to the main scanning direction with use of a 
plurality of image sensors aligned in the main scanning 
direction; calculating difference per image sensor between 
a maximum value among a plurality of readings from each 

25 image sensor and an average value of readings from each 
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image sensor; and obtaining the shading correction 
coefficient by adding a value corresponding to the 
difference of each image sensor to a correction coefficient 
so that the maximum value of each image sensor becomes a 
5 specified image level. 

[0012] A third aspect of the present invention provides 

an image reading method for obtaining a shading correction 
coefficient for correcting image data obtained by reading a 
document image, comprising the steps of: reading a 

10 reference plate in a main scanning direction plural times 
at different positions in a sub-scanning direction 
perpendicular to the main scanning direction with use of a 
plurality of image sensors aligned in the main scanning 
direction; calculating difference between an average value 

15 of maximum values among a plurality of readings from each 
image sensor and an average value of readings from each 
image sensor; and obtaining the shading correction 
coefficient by modifying a correction coefficient for 
correcting the image data so that the maximum value of each 

20 image sensor becomes a specified image level in 
correspondence to the difference of each image sensor. 
[0013] A fourth aspect of the present invention provides 
an image reading device for obtaining a shading correction 
coefficient for correcting image data obtained by reading a 

25 document image, comprising: a plurality of image sensors 
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aligned in a main scanning direction; a calculation section 
for reading a reference plate in the main scanning 
direction plural times at different positions in a sub- 
scanning direction perpendicular to the main scanning 
5 direction with use of the image sensors and calculating 
difference between an average value of maximum values among 
a plurality of readings from each image sensor and an 
average value of readings from each image sensor; an 
operation section for obtaining the shading correction 

10 coefficient by modifying a correction coefficient for 
correcting the image data so that the maximum value of each 
image sensor becomes a specified image level in 
correspondence to the difference of each image sensor; and 
a correction section for correcting image data obtained by 

15 reading a document image with use of the image sensors 
through the shading correction coefficient. 

[0014] A fifth aspect of the present invention provides 
an image reading method for obtaining a shading correction 
coefficient for correcting image data obtained by reading a 

20 document image, comprising the steps of: reading a 
reference plate in a main scanning direction plural times 
at different positions in a sub-scanning direction 
perpendicular to the main scanning direction with use of a 
plurality of image sensors aligned in the main scanning 

25 direction; calculating difference between an average value 



of maximum values among a plurality of readings from each 
image sensor and an average value of readings from each 
image sensor; and obtaining the shading correction 
coefficient by adding a value corresponding to the 
5 difference of each image sensor to a correction coefficient 
so that the maximum value of each image sensor becomes a 
specified image level. 

[0015] A sixth aspect of the present invention provides 
an image reading device, comprising: a plurality of image 

10 sensors aligned in a main scanning direction; calculation 
means for reading a reference plate in the main scanning 
direction plural times at different positions in a sub- 
scanning direction perpendicular to the main scanning 
direction with use of the image sensors and calculating 

15 difference per image sensor between a maximum value among a 
plurality of readings from each image sensor and an average 
value of readings from each image sensor; amplification 
means for amplifying image signals read by the image 
sensors; and gain adjustment means for changing an 

20 amplification factor of the amplification means in 
correspondence to the calculated difference. 

[0016] A seventh aspect of the present invention 

provides an image reading device, comprising: a plurality 
of image sensors aligned in a main scanning direction; 
25 calculation means for reading a reference plate in the main 
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scanning direction plural times at different positions in a 
sub-scanning direction perpendicular to the main scanning 
direction with use of the image sensors and calculating 
difference between an average value of maximum values among 
5 a plurality of readings from each image sensor and an 
average value of readings from each image sensor; 
amplification means for amplifying image signals read by 
the image sensors; and gain adjustment means for changing 
an amplification factor of the amplification means in 

10 correspondence to the calculated difference. 

[0017] A eighth aspect of the present invention provides 
an image reading device, comprising: amplification means 
for amplifying signals representing images of a reference 
intensity plate or an image document with a specified 

15 amplification factor to provide readings of the reference 
intensity plate or readings of the image document; peak 
value calculation means for calculating a peak value of the 
readings of the reference intensity plate; storage means 
for storing the peak value; average value calculation means 

20 for calculating an average value of the readings of the 
reference intensity plate; difference data calculation 
means for calculating difference data between the peak 
value and the average value; compensation coefficient 
setting means for setting a compensation coefficient 

25 through use of the peak value stored in the storage means 
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as shading compensation reference data; compensation means 
for compensating readings of the image document through use 
of the compensation coefficient; and gain adjustment means 
for changing the amplification factor of the amplification 
5 means according to the difference data so as to make the 
amplification factor for use in the case where the 
amplification means amplifies signals representing images 
of the reference intensity plate different from the 
amplification factor for use in the case where the 
10 amplification means amplifies signals representing images 
of the image document. 

[0018] It is noted that the "reference plate" refers to 

a plate having reference intensity, provided for obtaining 
shading correction reference data, and the "readings of a 

15 reference plate" refer to data values obtained through 
optical reading of such a reference plate. The "image data 
obtained by reading a document image" refer to image data 
values obtained through optical reading of an document 
image with use of the same optical reading system as in 

20 reading the reference plate. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0019] The present invention will become more fully 

understood from the detailed description given hereinbelow 
and the accompanying drawings which are given by way of 
25 illustration only, and thus are not limitative of the 
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present invention, and wherein: 

[0020] Fig. 1 exemplifies a reading wavelength of a 

shading plate in the case where an optical reading system 
contains a certain degree of noise and therefore S/N ratio 
5 is inappropriate. 

[0021] Fig. 2 shows readings of an document image after 

a shading correction according to one embodiment of the 
present invention in comparison with a prior art shading 
correction; 

10 [0022] Fig. 3 shows a circuitry of a shading correction 

section for implementing a first shading correction 
according to the present invention; 

[0023] Fig. 4 shows a circuitry of a shading correction 

section for implementing a second shading correction 
15 according to the present invention; 

[0024] Fig. 5 shows correction coefficients for use in 

implementing the first shading correction; 

[0025] Fig. 6 shows values to be subtracted from data 

values outputted from a FIFO memory by a subtracter upon 
2 0 reading of a shading plate in implementing the second 
shading correction; 

[0026] Fig. 7 shows variable amplification factors of a 

gain circuit in implementing third shading correction; 
[0027] Fig. 8 shows a sequence of the implementing first 
25 shading correction; 
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[0028] Fig. 9 shows a sequence of implementing the 

second shading correction; 

[0029] Fig. 10 shows a sequence of implementing the 

third shading correction; 

[0030] Fig. 11 shows a schematic block structure of the 

image reading device in one embodiment of the present 
invention applied to an image reader of a color digital 
copying machine; and 

[0031] Figs. 12A and 12b show schematic views for 

indicating a problem of shading correction when large 
noises are present in a system. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
[0032] Hereinbelow, the present invention will be 

described in detail with reference to illustrated 
embodiments . 

[0033] Fig. 11 shows a schematic block structure of an 

image reading device in one embodiment of the present 
invention, which device is applied to an image reader (IR) 
of an electro-photographic digital color copying machine. 
The image reading device is equipped with a CCD-type line 
sensor (hereinafter referred to as a "CCD sensor") 1, a 
sample hold section (S/H) 2, a clamp circuit (CLP) 3, a 
gain circuit as an amplification means (AMP) 4, an A/D 
conversion section (A/D) 5, a shading correction section 
(SH) 6, and a central processing unit (CPU) 10 for 
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controlling the entire image reading device. A document 8 
or a shading plate 9 having a white level reference density 
is radiated by a fluorescent lamp (unshown) as a light 
source, and a reflected ray of light thereof travels 
5 through an optical system (unshown) and becomes incident on 
the CCD sensor 1. The shading correction plate 9 is 
actually long and slender in a main scanning direction like 
the CCD sensor 1. 

[0034] The CCD sensor 1 conducts photoelectric 

10 conversion of light from the document 8 or the shading 
plate 9, and outputs analog signals composed of color 
analyzing information of each R (red), G (green) and B 
(blue) color. The sample hold section 2 holds valid signal 
parts of the analog signals and sends them to the clamp 

15 circuit 3. The clamp circuit 3 regulates offset amount of 
black level in relation to the analog signals, and sends 
them to the gain circuit 4. The gain circuit 4 amplifies 
the analog signals with a specified amplification factor, 
and transmits them to the A/D conversion section 5. The 

2 0 A/D conversion section 5 converts the analog signals to 8- 
bit (256 steps) digital data per R, G and B color 
information based on a timing signal transferred from the 
CPU 10, and then sends them to the shading correction 
section 6. The shading correction section 6 executes peak- 

25 hold-type shading correction of the digital data, and 



forwards them to a following unshown image processing 
circuit (such as a color aberration correcting section) . 
[0035] In general, peak-hold-type shading correction is 

performed as follows. Image data for a plurality of lines 
on the shading plate 9 are read in advance, and then a peak 
value of the image data is held per corresponding pixel on 
each line as reference data of shading correction. Upon 
reading of a document, the shading correction section 6 
uses the correction reference data to correct readings of 
the document image so that the shading is eliminated. 
[0036] Fig. 1 exemplifies reading wavelengths of a 

shading plate 9 in the case where an optical reading system 
contains a certain degree of noise elements and therefore 
S/N ratio is inappropriate. Here, a horizontal axis 
represents a main scanning direction position, whereas a 
vertical axis represents reading (0 indicates a black 
level) . Reflecting noises of the system, the readings are 
dispersed from a lower dotted wave line representing a 
minimum value "min" to an upper doted wave line 
representing a peak value peak, between which a line of an 
average value "ave" is interposed. PO and AO each denote 
an average value obtained by averaging the peak value 
"peak" and the average value "ave" of pixels in a central 
portion of the main scanning direction as a valid area, the 
central portion of which is indicated by a range with 
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arrows in Fig. 1. Difference data "delt" obtained by 
subtracting a value AO from a value PO corresponds to a 
noise amount (S/N ratio) . 

[0037] Fig. 2 shows readings of an document image after 
5 a shading correction according to the present invention in 
comparison with a prior art shading correction so as to 
represent how the readings of a document having a certain 
density vary in response to a noise amount. In Fig. 2, a 
horizontal axis represents the "delt (=PO-AO) " shown in 

10 Fig.l, whereas a vertical axis represents readings. Zero 
on the vertical axis refers to a black level. 
[0038] In the prior art peak-hold-type shading 

correction, as shown with a broken straight line DATAOUTB, 
increase of the difference data "delt" from 0 to 10a 

15 decreases the readings from X to Y in proportion thereto. 

[0039] More particularly, in Fig. 2, X refers to a 

reading of a certain density patch after shading correction 
in the case where no noise (delt=0) is present in the 
system. The reading X is expressed by the following 

2 0 numerical formula: 

X = XO x (255/AO) ...(1) 
where 255 is a white level (shading plate) target value, AO 
is a peak hold value of a shading plate in the case of no 
noise and equal to an average value thereof, and X0 is an 

25 average reading of a density patch before application of 
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shading correction. 

[0040] In the case where a certain noise amount is 

present, for example, where a noise amount "delt" equals to 
a maximum value 10a, the reading Y after application of 
5 shading correction is expressed as follows: 
Y = XO x (255/ (AO + 10a) ) 

= X x AO/ (AO + 10a) ...(2) 
[0041] In the prior art, as is clear from the above 

numerical formulas (1) and (2), the difference data "delt" 
10 increasing from 0 to 10a decreases the reading from X to Y 
in proportion thereto, and the more a reading target 
density approximates to a white level, the larger the 
difference (X-Y) becomes. 

[0042] On the other hand, the following shading 

15 corrections of the present invention is implemented in 
order to decrease dispersion caused by the influence of S/N 
ratio in readings of document images after the shading 
correction, as shown in sawtooth wave DATAOUTA depicted 
with a solid line in Fig. 2 
20 [0043] Fig. 3 shows an example of circuitry of the 

shading correction section 6 for a first shading correction 
according to the present invention. In this example, the 
shading correction section 6 is equipped with a FIFO 
(first-in first-out) memory 11 as a storage means for 
25 storing shading correction reference data, a comparator 
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(COMP) 12, a RAM 13 for storing a correction coefficient 
table (SHTABLE) , and a multiplier 14. 

[0044] During reading of shading correction reference 

data, the comparator 12 compares uncorrected reading DATAIN 
5 and output data from the FIFO memory 11, and selects larger 
one therefrom to send it to an input terminal of the FIFO 
memory 11. Thus, a peak value of uncorrected readings upon 
reading of a shading plate is stored in the FIFO memory 11 
as shading correction reference data. Output data (a peak 
10 hold value) of the FIFO memory 11 called FIFOout is 
connected to an address of the RAM 13. In the RAM 13, 
there is stored a correction coefficient table (SHTABLE) 
shown in Fig. 5. 

[0045] In the correction coefficient table, difference 

15 data "delt" (=P0-A0) , which corresponds to a noise amount, 
is divided into five ranges i.e. five banks of 0 to 2a, 2a 
to 4a, 4a to 6a, 6a to 8a, and 8a to 10a, and there is 
stored a correction coefficient of the difference data 
"delt" corresponding to each bank upon reading of a shading 
20 plate. The first factor of the correction coefficients is 
(255/FIFOout) . The denominator FIFOout represents a peak 
hold value outputted from the FIFO memory 11. Therefore, 
the first factor (255/FIFOout) of the correction 
coefficients indicates that a white level target value i.e. 
25 a white level of the shading plate should be set to a 
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maximum step value 255. 

[0046] In the case of a bank 0 where noises are small 

and the difference data "delt" is in the range of 0 (no 
noise) to 2a, the second factor equals to ((AO) /(AO)) = 1, 
5 and therefore the correction coefficient is (255/FIFOout ) . 
In the case of a bank 1 where noises are slightly increased 
and the difference data "delt" is in the range of 2a to 4a, 
the second factor equals to ( (A0+2a) /AO) ) , so that the 
correction coefficient is increased from (255/FIFOout) by 

10 that incremental portion. In the same way, in the case of 
a bank 2 where the difference data "delt" is in the range 
of 4a to 6a, the second factor equals to ( (A0+4a) /AO) ) , so 
that the correction coefficient is increased from 
(255/FIFOout) by that incremental portion. In the case of 

15 a bank 3 where the difference data "delt" is in the range 
of 6a to 8a, the second factor equals to ( (A0+ 6a) /AO ) ) , so 
that the correction coefficient is increased from 
(255/FIFOout) by that incremental portion. In the case of 
a bank 4 where the difference data "delt" is in the range 

20 of 8a to 10a, the second factor equals to ( (A0+8a) /AO) ) , so 
that the correction coefficient is increased from 
(255/FIFOout) by that incremental portion. 

[0047] Fig. 8 shows a sequence executed by the CPU 10 of 
Fig. 11 for setting the correction coefficient table for 
25 use in first shading correction. 
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[0048] First, each part in the shading correction 

section 6 is initialized (SO) . Next, data for one line on 
the shading plate is read out (Si) . Then, one line data is 
written onto the FIFO memory 11 for storing peak hold 
5 values. Out of the written data, data on pixels included 
in a central portion of the main scanning direction is read 
out and averaged in relation to the main scanning direction 
so that an average value AO is obtained (S2) . Next, data 
on the shading plate is read out N times and peak hold 

10 values thereof are written onto the FIFO memory 11 (S3) . 

Upon completion of writing, data on the pixels included in 
the central portion of the main scanning direction is read 
out, and averaged in relation to the main scanning 
direction so that an average value PO is obtained (S4) . 

15 Then, difference data delt = PO - AO is calculated (S5) . 

[0049] Next, a parameter "n" for selecting a bank is set 
to 0 (S6) , and determination is made if a value of the 
difference data "delt" is smaller than 2a x n or not (S7) . 
If the value of the difference data "delt" is not smaller 

2 0 than 2a x n, gradual increment of the value "n" is 
implemented, and a bank "n" to which the difference data 
"delt" belongs is finally selected (S8) . Then, the 
correction coefficient table (SHTABLE) corresponding to the 
selected bank "n" is loaded to the RAM 13 (S9) . 

25 [0050] Upon reading of a document, the multiplier 14 
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shown in Fig. 3 multiplies an uncorrected reading DATAIN by 
a correction coefficient read from the correction 
coefficient table (SHTABLE) in the RAM 13, and outputs 
multiplication result DATAOUT . The multiplication result 
5 DATAOUT is expressed by following five formulas (3) in 
accordance with the bank "n", i.e. the range of difference 
data "delt". 

When delt = 0 to 2a, 

DATAOUT = (255/FIFOout) x ( (AO) /AO) x DATAIN 
10 When delt =2a to 4a, 

DATAOUT = (255/ FIFOout ) x ( (A0+2a) /AO ) xDATAIN 
When delt =4a to 6a, 

DATAOUT = (255/ FIFOout) x ( (A0+4a) /AO) xDATAIN 
When delt =6a to 8a, 
15 DATAOUT = (255/ FIFOout ) x ( (A0+ 6a) /AO ) xDATAIN 

When delt =8a to 10a, 

DATAOUT = (255/ FIFOout) x ( (AO + 8a) /AO ) xDATAIN 
...(3) 

[0051] According to the formulas (3), a reading result 

20 when conducting the first shading correction shows a 
sawtooth wave DATAOUTA depicted with a solid line in Fig. 2. 
Therefore, compared to peak-hold-type shading correction 
based on the prior art (shown as DATAOUT B drawn with broken 
straight line) , the dispersion in readings after 
25 application of shading correction caused by the influence 



of S/N ratio can be decreased. 

[0052] More particularly, a dispersion amount (X-Y) in 

the case of the prior art equals to: 

X-Y = X-X x A0/(A0+10a) 
= X x 10a/ (AO+lOa) 
[0053] Next, in obtaining a dispersion amount (X-Z) in 

the case of implementing the first shading correction, a 
lower limit value Z of dispersion equals to: 

Z= X x A0/(A0+2a) (provided that A0»10a) 
[0054] Therefore, a dispersion amount (X-Z) in the case 

of implementing the first shading correction is obtained by 
the following formula: 

X-Z = X - X x A0/(A0+2a) 
= X x 2a/ (A0+2a) 
[0055] Consequently, comparison of a dispersion amount 

of readings between the shading correction based on the 
prior art and the first shading correction is expressed as 
follows : 

(X-Y) / (X-Y) 

= (X x Sa/ (A0+2a) ) / (XxlOa/ (AO+lOa) ) 

- (2a/ (A0+2a) ) / (10a/ (AO+lOa) } 

- (1/ (A0+2a) )/ (5/ (AO+lOa) ) 
almost equal to 1/5 (as A0»10a) 

[0056] Therefore, the first shading correction can 

decrease the dispersion in readings of an document image to 
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approximately one fifth of the prior art shading correction. 
[0057] Fig. 4 shows a circuitry example of the shading 

correction section 6 for a second shading correction 
according to the present invention. In this example, the 
5 shading correction section 6 is equipped with a FIFO memory 
21 as a storage means for' storing shading correction 
reference data, a comparator (COMP) 22, a subtracter 25, a 
RAM 23 for storing a correction coefficient table (SHTABLE) , 
and a multiplier 24. 

10 [0058] During reading of shading correction reference 

data, as in the case of the previous example, the 
comparator 22 compares uncorrected reading DATAIN and 
output data from the FIFO memory 21, and selects larger one 
therefrom to send it to an input terminal of the FIFO 

15 memory 21. Thus, a peak value of uncorrected readings upon 
reading of a shading plate is stored in the FIFO memory 21 
as a shading correction reference data. A specified value 
"diff" described hereinafter is subtracted from FIFOout, 
that is output data of the FIFO memory 21 (a peak hold 

2 0 value) , and then the FIFOout is connected to an address of 
the RAM 23. In the RAM 23, there is stored in this example, 
data on a correction coefficient table (SHTABLE) as 
described below. 

255/ (FIFOout-dif f ) ...(4) 

25 [0059] Fig. 6 shows values of "diff" to be subtracted 



23 



from a data value outputted from a FIFO memory 21 by a 
subtracter 25 upon reading of a shading plate. The 
difference data "delt" (=P0-A0) , which corresponds to a 
noise amount, is divided into five ranges (banks) of 0 to 
5 2a, 2a to 4a, 4a to 6a, 6a to 8a and 8a to 10a. Upon 
reading of a shading plate, the value "diff" is set in 
accordance with each bank of the difference data "delt". 
[0060] In the case of a bank 0 where noises are small 

and the difference data "delt" is in the range of 0 to 2a, 

10 the value "diff" is set to zero. In the case a bank 1 
where noises are slightly increased and the difference data 
"delt" is in the range of 2a to 4a, the value "diff" is set 
to 2a. In the case of a bank 2 where the difference data 
"delt" is in the range of 4a to 6a, the value "diff" is set 

15 to 4a. In the case of a bank 3 where the difference data 
"delt" is in the range of 6a to 8a, the value "diff" is set 
to 6a. In the case of a bank 4 where the difference data 
"delt" is in the range of 8a to 10a, the value "diff" is 
set to 8a. 

20 [0061] Fig. 9 shows a sequence executed by the CPU 10 

for setting the correction coefficient table for use in the 
second shading correction. 

[0062] First, each part in the shading correction 

section 6 is initialized (S10) . In this example in 
25 particular, the parameter "diff" is set to 0. Next, as 
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with the first shading correction, data for one line on a 
shading plate is read out (Sll) . Then, one line data is 
written onto the FIFO memory 11 dedicated for storing peak 
hold values. Out of the written data, data on pixels 

5 included in a central portion of the main scanning 
direction is read out and averaged in relation to main 
scanning direction so that an average value AO is obtained 
(S12) . Next, data on the shading plate is read out N times 
and peak hold values thereof are written onto the FIFO 

10 memory 11 (S13) . Upon completion of writing, data on the 
pixels included in the central portion of the main scanning 
direction is read out, and averaged in main scanning 
direction so that an average value PO is obtained (S14) . 
Then, difference data "delt" = PO - AO is calculated (S15) . 

15 [0063] Next, a parameter "n" for selecting a bank is set 
to 0 (S16), and determination is made if a value of the 
difference data "delt" is smaller than 2an or not (S17) . 
If the value of the difference data "delt" is not smaller 
than 2an, gradual increment of the value n is implemented, 

20 and a bank n to which the difference data "delt" belongs is 
finally selected (S18) . Then, a value "diff" corresponding 
to the selected bank n is selected, and the correction 
coefficient table (SHTABLE) expressed with the above-stated 
formula (4) is loaded to the RAM 13 (S19) . 

25 [0064] Upon reading of a document, the multiplier 24 
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shown in Fig. 4 multiplies an uncorrected reading DATAIN by 
a correction coefficient read from the correction 
coefficient table (SHTABLE) in the RAM 13, and outputs a 
multiplication result DATAOUT . The multiplication result 
DATAOUT is expressed by following five formulas (5) in 
accordance with the bank "n", i.e. the range of difference 
data "delt". 

When delt = 0 to 2a, 

DATAOUT = (255/ FIFOout) xDATAIN 

When delt =2a to 4a, 

DATAOUT = (255/ (FIFOout -2a)) x DATAIN 
When delt -4a to 6a, 

DATAOUT = (2 55/ (FIFOout -4a)) x DATAIN 
When delt =6a to 8a, 

DATAOUT = (255/ (FIFOout -6a)) x DATAIN 
When delt =8a to 10a, 

DATAOUT = (255/ (FIFOout -8a)) x DATAIN 
...(5) 

[0065] According to the formulas (5), a reading result 

when conducting the second shading correction shows a 
sawtooth wave DATAOUTA depicted with a solid line in Fig. 2 
as with the case of conducting the first shading correction. 
Therefore, compared to peak-hold-type shading correction 
based on the prior art (shown as DATAOUTB drawn with broken 
straight line) , the dispersion in readings after 
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application of shading correction caused by the influence 
of S/N ratio can be decreased. 

[0066] In a third shading correction according to the 

present invention, the shading correction section 6 has a 
5 block structure identical to that shown in Fig. 3. Further, 
in this example, the following is stored in the RAM 13 as 
contents of the correction coefficient table SHTABLE like 
the case of the prior art: 
255/(FIFOou) ...(6) 

10 [0067] In the third shading correction, however, an 

amplification factor of the gain circuit AMP 4 shown in Fig. 
11 is so changed as to eliminate the influence of S/N ratio 
on readings. Although not mentioned in the case of the 
first and second shading corrections for the purpose of 

15 simplification, the amplification factor of the gain 
circuit 4 is set to a constant amplification factor GO 
during reading both the shading plate and the document 
images . 

[0068] Fig. 7 shows a variable amplification factor Gl 

20 of the gain circuit 4. The difference data "delt" (=P0-A0) 
that corresponds to a noise amount is divided into 5 ranges 
(banks) of 0 to 2a, 2a to 4a, 4a to 6a, 6a to 8a and 8a to 
10a. The amplification factor Gl is set in accordance with 
each bank of the difference data "delt" upon reading of a 
25 shading plate. The dividing rule thereof is identical to 
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that in the case of the first and the second shading 
corrections. In the case of a bank 0 where noises are 
small and the difference data "delt" is in the range of 0 
to 2a, the amplification factor Gl is set to Gl=GOx 
5 ((AO) /AO) =G0. In the case of a bank 1 where noises 

are slightly increased and the difference data "delt" is in 
the range of 2a to 4a, the amplification factor Gl is set 
to Gl=G0x ( (A0+2a) /AO) . In the case of a bank 2 where the 
difference data "delt" is in the range of 4a to 6a, the 

10 amplification factor Gl is set to Gl=G0x ( (A0+4a) /AO) . In 
the case of a bank 3 where the difference data "delt" is in 
the range of 6a to 8a, the amplification factor Gl is set 
to Gl=G0x ( (A0+6a) /AO) . In the case of a bank 4 where the 
difference data "delt" is in the range of 8a to 10a, the 

15 amplification factor Gl is set to Gl=G0x ( (A0+8a) /AO) . 

[0069] Fig. 10 shows a sequence for setting an 

amplification factor Gl of the gain circuit 4 for use in 
implementing the third shading correction. 

[0070] First, each part in the shading correction 

20 section 6 is initialized (S20) . In this example in 
particular, the parameter is set to G1=G0 . Next, as with 
the first and the second shading corrections, data for one 
line on a shading plate is read out (S21) . More 
particularly, the CCD sensor 1 shown in Fig. 11 conducts 
25 photoelectric conversion of light from the shading plate 9, 
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and outputs analog signals composed of R, G, and B. The 
sample hold section 2 holds valid signal parts of the 
analog signals and sends them to the clamp circuit 3. The 
clamp circuit 3 regulates a black level offset amount in 
5 relation to the analog signals, and sends the signals to 
the gain circuit 4. The gain circuit 4 amplifies the 
analog signals with an amplification factor GO, and 
transmits them to the A/D conversion section 5. The A/D 
conversion section 5 converts the analog signals to 8-bit 

10 (256 steps) digital data per R, G, and B color information 
based on a timing signal transferred from the CPU 10, and 
sends them to the shading correction section 6. In the 
shading correction section 6, one line data is written onto 
the FIFO memory 11 shown in Fig. 3. Out of the written 

15 data, data on pixels included in a central portion of the 
main scanning direction is read out and averaged in 
relation to main scanning direction so that an average 
value AO is obtained (S22) . Next, data on the shading 
plate is read out N times and peak hold values thereof are 

2 0 written onto the FIFO memory 11 (S23) . Upon completion of 
writing, data on the pixels included in the central portion 
of the main scanning direction is read out, and averaged in 
main scanning direction so that an average value PO is 
obtained (S24) . Then, difference data "delt" = PO - AO is 

25 calculated (S25) . 
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[0071] Next, a parameter "n" for selecting a bank is set 
to 0 (S26) , and determination is made if a value of the 
difference data "delt" is smaller than 2axn or not (S27) . 
If the value of the difference data "delt" is not smaller 
5 than 2axn, gradual increment of the value "n" is 
implemented, and a bank "n" to which the difference data 
"delt" belongs is finally selected (S28) . Then, the 
amplification factor of the gain circuit 4 is set to a Gl 
value corresponding to the selected bank "n" (S29) . 

10 [0072] Upon reading of a document, the CCD sensor 1 

shown in Fig. 11 conducts photoelectric conversion of light 
from the document 8, and outputs analog signals of R, G, 
and B. The sample hold section 2 holds valid signal parts 
of the analog signals and sends them to the clamp circuit 3. 

15 The clamp circuit 3 regulates a black level offset amount 
of the analog signals, and sends the signals to the gain 
circuit 4. The gain circuit 4 amplifies the analog signals 
with an amplification factor Gl, and transmits them to the 
A/D conversion section 5. The A/D conversion section 5 

20 converts the analog signals to 8-bit (256 steps) digital 
data per R, G, and B color information based on a timing 
signal transferred from the CPU 10, and sends them to the 
shading correction section 6. In the shading correction 
section 6, the multiplier 14 shown in Fig. 3 multiplies an 

25 uncorrected reading DATAIN by a correction coefficient read 
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from the correction coefficient table (SHTABLE) in the RAM 
13, and outputs a multiplication result DATAOUT. The 
multiplication result DATAOUT is expressed by the following 
five formulas (7) in accordance with bank "n" i.e. the 
range of the difference data "delt" (provided that a factor 
GO is omitted for simplification) . 
When delt = 0 to 2a, 

DATAOUT = (255/ FIFOout) x ((AO) /AO) x DATAIN 
When delt =2a to 4a, 

DATAOUT = (255/ FIFOout) x ((A0+2a)/A0) x DATAIN 
When delt =4a to 6a, 

DATAOUT = (255/ FIFOout) x ((A0+4a)/A0) x DATAIN 
When delt =6a to 8a, 

DATAOUT = (255/ FIFOout) x ((A0+6a)/A0) x DATAIN 
When delt =8a to 10a, 

DATAOUT = (255/ FIFOout) x ((A0+8a)/A0) x DATAIN 
...(7) 

[0073] According to the formulas (7), a reading result 

when conducting the third shading correction shows a 
sawtooth wave DATAOUTA depicted with a solid line in Fig. 2 
as with the case of conducting the first and the second 
shading corrections. Therefore, compared to peak-hold-type 
shading correction based on the prior art (shown as 
DATAOUTB drawn with broken straight line) , the dispersion 
in readings after application of shading correction under 
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influence of S/N ratio can be decreased. 

[0074] In this embodiment, the difference data "delt" 

(=P0-A0) that corresponds to a noise amount is divided into 
five ranges (banks) of 0 to 2a, 2a to 4a, 4a to 6a, 6a to 
5 8a, and 8a to 10a. According to these banks, the 
correction coefficient of the shading correction section 6 
and the amplification factor of the gain circuit 4 are 
regulated. However, the number of the banks is not limited 
to five. The number of the banks may be selected so that 

10 the dispersion in readings attributed to fluctuation of S/N 
ratio can be confined to a permissible level which is 
specified by a product specification setting and the like. 
For example, the number of banks may be two. The upper 
limit in the number of the banks is infinite. Therefore, 

15 the correction coefficient of the shading correction 
section 6 and the amplification factor of the gain circuit 
4 may be continuously regulated. In that case, diff=delt 
is set in the second shading correction for example. 
[0075] In order to calculate a peak value PO and an 

20 average value AO in reading the shading plate, data on 
pixels included in a central portion of each main scanning 
direction is averaged in relation to the main scanning 
direction. The reason why the plurality of pixels are 
subjected to calculation is to avoid such an adverse 

25 influence as the problematic dispersion in measurement in a 
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system having an inappropriate S/N ratio. Therefore, if 
the influence due to the dispersion in measurement does not 
become a problem, only one pixel in the central portion of 
the main scanning direction may be subjected to calculation. 
5 In that case, the image reading device may have a structure 
in which the difference data "delt" of each pixel of the 
main scanning direction is calculated per pixel, and the 
correction coefficient also takes a different value per 
pixel of the main scanning direction. 

10 [0076] Generally, it is known that readings on a shading 
plate is different by luminous intensity distribution 
properties and by a main scanning direction position, while 
the difference data "delt" is approximately constant 
regardless of the position of the main scanning direction. 

15 Therefore, there is no problem about obtaining a peak value 
PO and an average value AO by averaging in main scanning 
direction data on a plurality of pixels in a central 
portion of the main scanning direction in this embodiment. 
In addition, if dirt is attached to the shading plate, the 

20 influence thereof is negligible because pixels in wide 
ranges are subjected to calculation. 

[0077] In the above embodiments, the average of peak 

values is obtained by averaging maximum output values from 
each CCD sensor aligned in the main scanning direction. 
25 The average of readings is obtained by averaging output 
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values of one line obtained from each CCD sensor after once 
reading the shading plate. Difference of these average 
values is obtained per line and used for shading correction 
and gain adjustment. However, it may be possible to 

5 obtain difference per CCD i.e. per pixel. More 
specifically/ the shading plate is read at an identical 
position or different positions plural times, and a peak 
value (maximum value) is obtained from plural readings from 
each CCD. Then, there is obtained an average value of the 

10 plural readings obtained from each CCD. Finally, there is 
obtained difference between the average value and the peak 
value. By using this difference per pixel, shading 
correction and gain adjustment per pixel may be performed. 
[0078] In the above embodiments, the average of readings 

15 of the reference plate is obtained by averaging readings of 
one line. However, it may be obtained by using all or part 
of readings of plural lines. 

[0079] The invention being thus described, it will be 

obvious that the invention may be varied in many ways . 
20 Such variations are not be regarded as a departure from the 
spirit and scope of the invention, and all such 
modifications as would be obvious to one skilled in the art 
are intended to be included within the scope of the 
following claims. 



